package cn.arnold.search;

import java.util.ArrayList;
import java.util.List;

public class SeqSearch {

    public static void main(String[] args) {
        int[] array1 = {1, 8, 10, 89, 1000, 1234};
        int[] array2 = {1, 8, 10, 8, 8, 89, 1000, 1234};
        int resIndex = searchOne(array1, 7);
        System.out.println(resIndex);
        List list = searchAll(array2, 8);
        System.out.println(list);
    }

    // 找到第一个匹配的就退出
    public static int searchOne(int[] array, int findValue) {
        // 线性查找就是逐一比对
        for (int i = 0; i < array.length; i++) {
            if (findValue == array[i]) {
                return i;
            }
        }
        return -1;
    }

    // 匹配所有的下标
    public static List searchAll(int[] array, int findValue) {
        List<Integer> list = new ArrayList<Integer>();
        // 线性查找就是逐一比对
        for (int i = 0; i < array.length; i++) {
            if (findValue == array[i]) {
                list.add(i);
            }
        }
        return list;
    }
}
